<template>
  <div class="wrapper">
    <ul class="list">
      <li class="list-item"
          v-for="(item, index) in showObj.form"
          :key="index">
        <span v-if="item.formType == 'date'">{{item.name +'&nbsp;“' + item.value[0] + '-' + item.value[1] + '”'}}</span>
        <span v-else-if="item.formType === 'datetime'">{{item.name +'&nbsp;“' + item.value[0] + '-' + item.value[1] + '”'}}</span>
        <span v-else-if="item.formType === 'business_type'">{{item.name +'&nbsp;“' + getTypesName(item) + getStatusName(item) + '”'}}</span>
        <span v-else-if="item.formType === 'map_address'">{{`${item.name} ${item.address.state} ${item.address.city} ${item.address.area}`}}</span>
        <span v-else-if="item.formType === 'checkStatus'">{{item.name +'&nbsp;“' + optionsNames[item.condition]+ '”'+'&nbsp;'+ getCheckName(item)}}</span>
        <span v-else-if="item.formType === 'user'">{{item.name +'&nbsp;' + optionsNames[item.condition] + '“' + item.value[0].realname + '”'}}</span>
        <span v-else-if="item.formType === 'category' && item.value.length > 0">{{item.name +'&nbsp;“' + item.valueContent + '”'}}</span>
        <span v-else>{{item.name + '&nbsp;' + optionsNames[item.condition] + '“' + item.value + '”' }}</span>
        <i class="el-icon-close icon"
           @click="handleDelete(item, index)"></i>
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  name: 'filterContent',
  props: {
    obj: {
      default: {},
      required: true
    }
  },
  watch: {
    obj: function(val) {
      this.showObj = val
    }
  },
  computed: {},
  data() {
    return {
      // 获取条件名称
      optionsNames: {
        is: '等于',
        isNot: '不等于',
        contains: '包含',
        notContains: '不包含',
        startWith: '开始于',
        endWith: '结束于',
        isNull: '为空',
        isNotNull: '不为空',
        eq: '等于',
        neq: '不等于',
        gt: '大于',
        egt: '大于等于',
        lt: '小于',
        elt: '小于等于'
      },
      //展示信息
      showObj: {}
    }
  },
  mounted() {
    this.showObj = this.obj
  },
  methods: {
    /**
     * 删除高级筛选条件
     * @param index
     */
    handleDelete(item, index) {
      this.$delete(this.showObj.obj, item.fieldName)
      this.showObj.form.splice(index, 1)
      this.$emit('delete', { item: item, index: index, obj: this.showObj })
    },
    // 商机组展示名称
    getTypesName(data) {
      if (data.typeId) {
        let obj = data.typeOption.find(item => {
          return item.typeId === data.typeId
        })
        return obj.name || ''
      }
      return ''
    },
    getCheckName(data) {
      let value=''
      data.setting.forEach(item=>{
        if(item.value===data.value){
          value=item.name;
          return;
        }
      })
      return value;
    },
    // 商机阶段展示名称
    getStatusName(data) {
      if (data.statusId) {
        let obj = data.statusOption.find(item => {
          return item.statusId === data.statusId
        })
        if (obj.name) {
          return '-' + obj.name
        }
        return ''
      }
      return ''
    }
  }
}
</script>

<style scoped lang="scss">
@mixin left() {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
@mixin center() {
  display: flex;
  justify-content: center;
  align-items: center;
}

.wrapper {
  width: 100%;
  min-height: 50px;
  background: white;
  border-top: 1px solid #e1e1e1;
  font-size: 13px;
  overflow-x: scroll;
  color: #aaa;
  @include left;
  .list {
    width: 100%;
    padding: 0 20px;
    margin-bottom: 10px;
    flex-shrink: 0;
    @include left;
    .list-item {
      height: 30px;
      padding: 0 10px;
      margin: 10px 15px 0 0;
      border: 1px solid #e1e1e1;
      border-radius: 3px;
      flex-shrink: 0;
      @include center;
      .icon {
        margin-left: 20px;
        cursor: pointer;
      }
    }
  }
}
</style>
